# **Hardware Debugging**

#### Introduction

In this lab you will use the uart\_led design that was introduced in the previous timing tutorial. You will use Mark Debug feature and also the available Integrated Logic Analyzer (ILA) core (in IP Catalog) to debug the hardware.

## **Objectives**

After completing this lab, you will be able to:

- Use the Integrated Logic Analyzer (ILA) core from the IP Catalog as a debugging tool
- Use Mark Debug feature of Vivado to debug a design
- Use hardware debugger to debug a design

#### **Procedure**

This lab is broken into steps that consist of general overview statements providing information on the detailed instructions that follow. Follow these detailed instructions to progress through the lab.

## **Design Description**

The design consists of a uart receiver receiving the input typed on a keyboard and displaying the binary equivalent of the typed character on the 8 LEDs. When a push button is pressed, the lower and upper nibbles are swapped. The block diagram is as shown in **Figure 1**.



Figure 1. The Completed Design



#### **General Flow**



In the instructions below;

{sources} refers to: ...\2016\_2\_artix7\_sources

{ labs } refers to : ...\2016\_2\_artix7\_labs

Board support for the Basys3, Nexys4 DDR, Nexys Video is not included in Vivado 2016.2 by default. The relevant zip files need to be extracted and saved to: {Vivado installation}\data\boards\board\_files\.

These files can be downloaded either from the Digilent, Inc. webpage (<a href="https://reference.digilentinc.com/vivado/boardfiles2015">https://reference.digilentinc.com/vivado/boardfiles2015</a>) or the XUP webpage (<a href="http://www.xilinx.com/support/university/vivado/vivado-workshops/Vivado-fpga-design-flow.html">http://www.xilinx.com/support/university/vivado/vivado-workshops/Vivado-fpga-design-flow.html</a>) where this material is also hosted.

# 1 Create a Vivado Project using IDE

Step 1

- 1-1. Launch Vivado and create a project targeting XC7A35TCPG236-1 (Basys3), XC7A100TCSG324-1 (Nexys4 DDR), or XC7A200TSBG484-1 (Nexys Video), and using the Verilog HDL. Use the provided Verilog and Xilinx Design Constraints source files from the {sources} Vab6 directory.
- 1-1-1. Open Vivado by selecting Start > All Programs > Xilinx Design Tools > Vivado 2016.2 > Vivado 2016.2
- **1-1-2.** Click **Create New Project** to start the wizard. You will see *Create A New Vivado Project* dialog box. Click **Next**.
- **1-1-3.** Click the Browse button of the *Project location* field of the **New Project** form, browse to **{labs}**, and click **Select**.
- **1-1-4.** Enter **lab6** in the *Project name* field. Make sure that the *Create Project Subdirectory* box is checked. Click **Next**.
- **1-1-5.** Select **RTL Project** option in the *Project Type* form, and click **Next**.
- **1-1-6.** Using the drop-down buttons, select **Verilog** as the *Target Language* and *Simulator Language* in the *Add Sources* form.



**1-1-7.** Click on the **Green Plus** button, then the **Add Files...** button and browse to the **{sources}\lab6** directory, select all the Verilog files (led\_ctl.v, meta\_harden.v, uart\_baud\_gen.v, uart\_led.v, uart\_rx.v, and uart\_rx\_ctl.v), click **OK**, and then click **Next**.

- **1-1-8.** Click **Next** to get to the *Add Cons*traints form.
- **1-1-9.** Click on the **Green Plus** button, then **Add Files...** and browse to the **{sources}\lab6** directory (if necessary), select *uart\_led\_timing.xdc* and the appropriate *uart\_led\_pins\_<box>board>.xdc* and click **Open**.
- 1-1-10. Click Next.
- **1-1-11.** In the *Default Part* form, using the **Parts** option and various drop-down fields of the **Filter** section, select the **XC7A100TCSG324-1** (for the Nexys4 DDR), the **XC7A35TCPG236-1** (for the Basys3), or **XC7A200tsbg484-1** for the Nexys Video.

Using the **Boards** option, you may also select the **Nexys4 DDR**, the **Basys3**, or the **Nexys Video** depending on your board.

- 1-1-12. Click Next.
- **1-1-13.** Click **Finish** to create the Vivado project.

#### 2 Add the ILA Core

Step 2

- **2-1-1.** Click **IP Catalog** under the *Project Manager* tasks of the *Flow Navigator* pane.
- **2-1-2.** The catalog will be displayed in the Auxiliary pane.
- **2-1-3.** Expand the **Debug & Verification > Debug** folders and double-click the **ILA** entry.





Figure 2. ILA in IP Catalog

This exercise will be connecting the ILA core/component to the LED port which is 8-bit wide.

- **2-1-4.** Change the component name to **ila\_led**.
- **2-1-5.** Change the *Number of Probes* to **2**.





Figure 3. Setting the component name and the number of probes field

2-1-6. Select the Probe Ports tab and change the PROBE1 port width to 8, leaving the PROBE0 width to 1.



Figure 4. Setting the probes widths

#### 2-1-7. Click OK.

The Generate Output Products dialog box will appear.





**Figure 5. The Generate Output Products** 

**2-1-8.** Click the **Generate** button to generate the core including the instantiation template. Click **OK** at the warning box. Notice the core is added to the *Design Sources* view.



Figure 6. Newly generate ila core added in the design source

- **2-1-9.** Select the **IP Sources** tab, expand the **IP(1) > ila\_led > Instantiation Template**, and double-click the **ila\_led.veo** entry to see the instantiation template.
- **2-1-10.** Instantiate the *ila\_led* in design by copying lines 56 62 and pasting to ~line 104 (before "endmodule" on the last line) in the uart\_led.v file.
- **2-1-11.** Change *your\_instance\_name* to **ila\_led\_i0**.
- **2-1-12.** Change the following port names in the Verilog code to connect the ila to existing signals in the design:

.clk(CLK) . clk(clk\_pin)

.probe0(PROBE0) . probe0(rx\_data\_rdy)
.probe1(PROBE1) . probe1(led\_pins)



```
105 ila_led ila_led_i0 (
106 .clk(clk_pin), // input wire clk
107 .probel(led_pins), // input wire [7 : 0] probe1
108 .probe0(rx_data_rdy) // input wire [0 : 0] probe0
109);
110
111 endmodule
```

Figure 7. Instantiating the ILA Core in the uart led.v

#### 2-1-13. Select File > Save File.

Notice that the ILA Core instance is in the design hierarchy.



Figure 8. ILA Core added to the design

# 3 Synthesize the Design and Mark Debug

Step 3

- 3-1. Synthesize the design. Open the synthesized design. View the schematic. Add Mark Debug on the rx\_data bus between the uart\_rx\_i0 and led\_ctl\_i0 instances.
- **3-1-1.** Click on **Run Synthesis** under the *Synthesis* tasks of the *Flow Navigator* pane.

The synthesis process will be run on the uart\_led.v and all its hierarchical files. When the process is completed a *Synthesis Completed* dialog box with three options will be displayed.

- **3-1-2.** Select the *Open Synthesized Design* option and click **OK**.
- **3-1-3.** Click on **Schematic** under the *Synthesized Design* tasks of *Synthesis* tasks of the *Flow Navigator* pane to view the synthesized design in a schematic view.
- **3-1-4.** Select the **rx\_data** bus between the *uart\_rx\_i0* and the *led\_ctl\_i0* instances, right-click, and select **Mark Debug**.





Figure 9. Marking a bus to debug

- 3-1-5. Select File > Save Constraints.
- **3-1-6.** Click **OK**, and then again **OK** to use **uart\_led\_timing.xdc** as the target.
- **3-1-7.** Select the **Netlist** tab and notice that the nets which are marked/assigned for debugging have a debug icon next to them.



Figure 10. Nets with debug icons

**3-1-8.** Select the **Debug** layout or **Layout > Debug**.

Notice that the **Debug** tab is visible in the Console pane showing Assigned and Unassigned Debug Nets groups.



Figure 11. Debug tab showing assigned and unassigned nets



**3-1-9.** Either click on the button in the left vertical tool buttons of the Debug pane, or right-click on the *Unassigned Debug Nets* and select the **Set up Debug...** option.

3-1-10. In the Set Up Debug wizard click Next.

Note that *rx\_data* is listed, with the Clock Domain as *clk\_pin\_IBUF\_BUFG*.



Figure 12. The remaining nets after removing already assigned nets in the Set Up Debug wizard

- **3-1-11.** Click **Next** and again **Next** (leaving everything as defaults) then **Finish**.
- **3-1-12.** In the Synthesized Design Schematic, click on the net on the output side of the BUFG for the input pin named clk\_pin. Hover over the now highlighted net and notice the name is clk\_pin\_IBUF\_BUFG. This is the clock net selected for the debug nets earlier.



Figure 13. Locating clk\_pin\_IBUF\_BUFG in the design



**3-1-13.** Right click on uart\_led\_pins\_<board>.xdc in the sources pane and select **Set as Target Constraint File**. This will save the changes to the file

- 3-1-14. Select File > Save Constraints and click OK and Click Yes.
- **3-1-15.** Open *uart\_led\_pins\_<board>.xdc* and notice the debug nets have been appended to the bottom of the file.
- **3-1-16.** Perform this step if synthesis is <u>not already</u> up-to-date: In the **Design Runs** tab, right-click on the synth\_1 and select **Force Up-to-Date** to ensure that the synthesis process is not re-run, since the design was not changed.



Figure 14. Forcing the design to be up-to-date

## 4 Implement and Generate Bitstream

Step 4

- 4-1. Generate the bitstream.
- **4-1-1.** Click on the **Generate Bitstream** to run the implementation and bit generation processes.
- **4-1-2.** Click **Yes** to run the implementation processes.
- **4-1-3.** When the bitstream generation process has completed successfully, a box with three options will appear. Select the **Open Hardware Manager** option and click **OK**.

# 5 Debug in Hardware

Step 5

- 5-1. Connect the board and power it ON. Open a hardware session, and program the FPGA.
- **5-1-1.** Make sure that the Micro-USB cable is connected to the JTAG PROG connector (next to the power supply connector). Make sure that the jumper is set to select USB power (JP3 on the Nexys4 DDR and JP2 on the Basys3).
- **5-1-2.** Turn ON the power.
- **5-1-3.** Select the *Open Hardware Manager* option and click **OK**.

The Hardware Manager window will open indicating "unconnected" status.

5-1-4. Click on the Open target link, then Auto Connect from the dropdown menu.

You can also click on the **Open recent target** link if the board was already targeted before.



**5-1-5.** The Hardware Session status changes from Unconnected to the server name and the device is highlighted. Also notice that the Status indicates that it is not programmed.

- **5-1-6.** Select the device and verify that the **uart\_led.bit** is selected as the programming file in the General tab. Also notice that there is an entry in the *Debug probes file* field.
- 5-2. Start a terminal emulator program such as TeraTerm or HyperTerminal. Select an appropriate COM port (you can find the correct COM number using the Control Panel). Set the COM port for 115200 baud rate communication. Program the FPGA and verify the functionality.
- **5-2-1.** Start a terminal emulator program such as TeraTerm or HyperTerminal.
- **5-2-2.** Select an appropriate COM port (you can find the correct COM number using the Control Panel).
- **5-2-3.** Set the COM port for 115200 baud rate communication.
- **5-2-4.** Right-click on the FPGA, and select **Program Device...** and click **Program**.

The programming bit file be downloaded and the DONE light will be turned ON indicating the FPGA has been programmed

The Debug Probes window will also open, if not, then select **Window > Debug Probes**. Notice that there are two debug cores, hw\_ila\_1 and hw\_ila\_2.



Figure 16. Debug probes

The hardware session status window also opens showing that the FPGA is programmed having two ila cores with the idle state.



Figure 17. Hardware session status for the Nexys4 DDR





Figure 17. Hardware session status for the Basys3



Figure 17. Hardware session status for the Nexys Video

**5-2-5.** Select the target FPGA (XC7A35T, XC7A100T, or XC7A200T), and click on the **Run Trigger Immediate** button to see the signals in the waveform window.



Figure 18. Opening the waveform window

Two waveform windows will be created, one for each ila; one ila is of the instantiated ILA core and another for the MARK DEBUG method.

- 5-3. Setup trigger conditions to trigger on a write to led port (rx\_data\_rdy=1) and the trigger position to 512. Arm the trigger.
- **5-3-1.** In the **Debug Probes** window, right-click on the **rx\_data\_rdy** and select **Add Probes to Basic Trigger Setup**.





Figure 19. Adding a signal to trigger setup

**5-3-2.** In the Basic Trigger Setup window, click on the drop-down button, set the compare value (== [B] X) and change the value from x to 1. Click **OK**.



Figure 20. Setting the trigger condition

**5-3-3.** Set the trigger position of the *hw\_ila\_1* to **512**.





Figure 21. Setting up the trigger position

- **5-3-4.** Similarly, set the trigger position of the *hw\_ila\_2* to **512**.
- **5-3-5.** Select the hw\_ila\_1 in the Hardware window and then click on the Run Trigger (button. Observe that the hw\_ila\_1 core is armed and showing the status as **Waiting for Trigger**.



Figure 22. Hardware analyzer running in capture mode

- **5-3-6.** In the terminal emulator window, type a character, and observe that the hw\_ila\_1 status changes from capturing to idle as the rx\_data\_rdy became 1.
- **5-3-7.** Select the hw\_ila\_data\_1.wcfg window and see the waveform. Notice that the rx\_data\_rdy goes from 0 to 1 at 512<sup>th</sup> sample and the led\_ctl\_i0 [7:0] bits also changes from 0 to the bit pattern corresponding to the character you typed.



Figure 23. Zoomed waveform view

**5-3-8.** Add the hw\_ila\_2 probes to the trigger window of the hw\_ila\_2 and change the trigger condtion for rx\_data[7:0]'s Radix from Hexadecimal to binary. Change XXXX\_XXXX to **0101\_0101** (for the ASCII equivalent of U).





Figure 24. Setting up trigger condition for a particular input pattern

- **5-3-9.** In the Hardware window, right-click on the **hw\_ila\_2** and select **Run Trigger**, and notice that the status of the hw\_ila\_2 changes from *idle* to *Waiting for Trigger*. Also notice that the hw\_ila\_1 status does not change from idle as it is not armed.
- **5-3-10.** Switch to the terminal emulator window and type **U** (shift+u) to trigger the core.
- **5-3-11.** Select the corresponding waveform window and verify that it shows 55 after the trigger.



Figure 25. Second ila core triggered

- 5-3-12. Demonstrate the trigger operation to the TA.
- 5-3-12. When finished, close the terminal emulator program and power OFF the board
- 5-3-13. Select File > Close Hardware Manager. Click OK to close it.
- **5-3-14.** Close the **Vivado** program by selecting **File > Exit** and click **OK**.

### Conclusion

You used ILA core from the IP Catalog and Mark Debug feature of Vivado to debug the hardware design.